

# MPASM™ and MPLINK™ PICmicro® MCU Quick Reference Guide



#### **MPASM Quick Reference Guide**

This Quick Reference Guide gives all the instructions, directives and command line options for the Microchip MPASM Assembler.

#### **MPASM Directive Language Summary**

| Directive          | Description                         | Syntax                                                                              |  |  |  |  |
|--------------------|-------------------------------------|-------------------------------------------------------------------------------------|--|--|--|--|
| Directive          | Description                         | Syntax                                                                              |  |  |  |  |
| CONTROL DIRECTIVES |                                     |                                                                                     |  |  |  |  |
| CONSTANT           | Declare Symbol Constant             | constant <label> [= <expr>,,<label> [= <expr>] ]</expr></label></expr></label>      |  |  |  |  |
| #DEFINE            | Define Text Substitution            | #define <name><br/>[[(<arg>,,<arg>)]<value>]</value></arg></arg></name>             |  |  |  |  |
| END                | End Program Block                   | end                                                                                 |  |  |  |  |
| EQU                | Define Assembly Constant            | <label> equ <expr></expr></label>                                                   |  |  |  |  |
| ERROR              | Issue an Error Message              | error " <text_string>"</text_string>                                                |  |  |  |  |
| ERROR-<br>LEVEL    | Set Messge Level                    | errorlevel 0 1 2 <+-> <msg></msg>                                                   |  |  |  |  |
| #INCLUDE           | Include Source File                 | include < <include_file>&gt; include "<include_file>"</include_file></include_file> |  |  |  |  |
| LIST               | Listing Options                     | list [ <option>[,,<option>]]</option></option>                                      |  |  |  |  |
| MESSG              | User Defined Message                | messg " <message_text>"</message_text>                                              |  |  |  |  |
| NOLIST             | Turn off Listing Output             | nolist                                                                              |  |  |  |  |
| ORG                | Set Program Origin                  | <label> org <expr></expr></label>                                                   |  |  |  |  |
| PAGE               | Insert Listing Page Eject           | page                                                                                |  |  |  |  |
| PROCESSOR          | Set Processor Type                  | processor <pre>cessor_type&gt;</pre>                                                |  |  |  |  |
| RADIX              | Specify Default Radix               | radix <default_radix></default_radix>                                               |  |  |  |  |
| SET                | Assign Value to Variable            | <label> set <expr></expr></label>                                                   |  |  |  |  |
| SPACE              | Insert Blank Listing Lines          | space [ <expr>]</expr>                                                              |  |  |  |  |
| SUBTITLE           | Specify Program Subtitle            | subtitl " <sub_text>"</sub_text>                                                    |  |  |  |  |
| TITLE              | Specify Program Title               | title " <title_text>"</title_text>                                                  |  |  |  |  |
| #UNDEFINE          | Delete a Substitution<br>Label      | #undefine <label></label>                                                           |  |  |  |  |
| VARIABLE           | Declare Symbol Variable             | variable <label> [= <expr>,,]</expr></label>                                        |  |  |  |  |
|                    | CONDITIONAL                         | ASSEMBLY                                                                            |  |  |  |  |
| ELSE               | Begin Alternative<br>Assembly to IF | else                                                                                |  |  |  |  |
| ENDIF              | End Conditional Assembly            | endif                                                                               |  |  |  |  |
| ENDW               | End a While Loop                    | endw                                                                                |  |  |  |  |
| IF                 | Begin Conditional ASM<br>Code       | if <expr></expr>                                                                    |  |  |  |  |
| IFDEF              | Execute If Symbol Defined           | ifdef <label></label>                                                               |  |  |  |  |
| IFNDEF             | Execute If Symbol Not Defined       | ifndef <label></label>                                                              |  |  |  |  |
| WHILE              | Perform Loop While True             | while <expr></expr>                                                                 |  |  |  |  |

#### **MPASM Directive Language Summary (Continued)**

| Directive | Description                                       | Syntax                                                                                                                     |  |  |  |
|-----------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|
|           | •                                                 | •                                                                                                                          |  |  |  |
| DATA      |                                                   |                                                                                                                            |  |  |  |
| BADRAM    | Specify invalid RAMbadram <expr> locations</expr> |                                                                                                                            |  |  |  |
| BADROM    | Specify invalid ROM locations                     | badrom <expr></expr>                                                                                                       |  |  |  |
| CBLOCK    | Define Block of Constants                         | cblock [ <expr>]</expr>                                                                                                    |  |  |  |
| CONFIG    | Set configuration bits                            | config <expr> OR<br/>config <addr>, <expr></expr></addr></expr>                                                            |  |  |  |
| DA        | Pack Strings in 14-bit<br>Memory                  | [ <label>] da <expr> [, <expr2>,, <exprn>]</exprn></expr2></expr></label>                                                  |  |  |  |
| DATA      | Create Numeric/Text Data                          | data <expr>,[,<expr>,,<expr>] data<br/>"<text_string>"[,"<text_string>",]</text_string></text_string></expr></expr></expr> |  |  |  |
| DB        | Declare Data of One Byte                          | db <expr>[,<expr>,,<expr>]</expr></expr></expr>                                                                            |  |  |  |
| DE        | Declare EEPROM Data                               | de <expr>[,<expr>,,<expr>]</expr></expr></expr>                                                                            |  |  |  |
| DT        | Define Table                                      | dt <expr>[,<expr>,,<expr>]</expr></expr></expr>                                                                            |  |  |  |
| DW        | Declare Data of One Word                          | dw <expr> [,<expr>,,<expr>]</expr></expr></expr>                                                                           |  |  |  |
| ENDC      | End CBlock                                        | endc                                                                                                                       |  |  |  |
| FILL      | Specify Memory Fill Value                         | fill <expr>, <count></count></expr>                                                                                        |  |  |  |
| IDLOCS    | Set ID locations                                  | idlocs <expr></expr>                                                                                                       |  |  |  |
| MAXRAM    | Specify max RAM adr                               | maxram <expr></expr>                                                                                                       |  |  |  |
| RES       | Reserve Memory                                    | res <mem_units></mem_units>                                                                                                |  |  |  |
|           | MACRO                                             | os                                                                                                                         |  |  |  |
| ENDM      | End a Macro Definition                            | endm                                                                                                                       |  |  |  |
| EXITM     | Exit from a Macro                                 | exitm                                                                                                                      |  |  |  |
| EXPAND    | Expand Macro Listing                              | expand                                                                                                                     |  |  |  |
| LOCAL     | Declare Local Macro<br>Variable                   | local <label> [,<label>]</label></label>                                                                                   |  |  |  |
| MACRO     | Declare Macro Definition                          | <label> macro [<arg>,,<arg>]</arg></arg></label>                                                                           |  |  |  |
| NOEXPAND  | Turn off Macro Expansion                          | noexpand                                                                                                                   |  |  |  |
|           | OBJECT FILE D                                     | IRECTIVES                                                                                                                  |  |  |  |
| BANKISEL  | Select Bank for indirect                          | bankisel <label></label>                                                                                                   |  |  |  |
| BANKSEL   | Select RAM bank                                   | banksel <label></label>                                                                                                    |  |  |  |
| CODE      | Executable code section                           | [ <name>] code [<address>]</address></name>                                                                                |  |  |  |
| CODE_PACK | Packed data in program memory                     | [ <name>] code_pack [<address>]</address></name>                                                                           |  |  |  |
| EXTERN    | Declare external label                            | extern <label> [ ,<label>]</label></label>                                                                                 |  |  |  |
| GLOBAL    | Export defined label                              | extern <label> [ .<label>]</label></label>                                                                                 |  |  |  |
| IDATA     | Initialized data section                          | [ <name>] idata [<address>]</address></name>                                                                               |  |  |  |
| PAGESEL   | Select ROM page                                   | pagesel <label></label>                                                                                                    |  |  |  |
| UDATA     | Uninitialized data section                        | [ <name>] udata [<address>]</address></name>                                                                               |  |  |  |
| UDATA_ACS | Access uninit data sect                           | [ <name>] udata_acs [<address>]</address></name>                                                                           |  |  |  |
| UDATA_OVR | Overlay uninit data sect                          | [ <name>] udata_ovr [<address>]</address></name>                                                                           |  |  |  |
| UDATA_SHR | Shared uninit data sect                           | [ <name>] udata_shr [<address>]</address></name>                                                                           |  |  |  |

#### **MPASM Radix Types Supported**

| Radix                 | Syntax                                                        | Example        |
|-----------------------|---------------------------------------------------------------|----------------|
| Decimal               | D' <digits>'<br/>.<digits></digits></digits>                  | D'100'<br>.100 |
| Hexadecimal (default) | H' <hex_digits>'<br/>0x<hex_digits></hex_digits></hex_digits> | H'9f'<br>0x9f  |
| Octal                 | O' <octal_digits>'</octal_digits>                             | O'777'         |
| Binary                | B' <binary_digits>'</binary_digits>                           | B'00111001'    |
| Character (ASCII)     | ' <character>'<br/>A'<character>'</character></character>     | A'C'           |

#### **MPLINK Command Line Options**

| Option       | Description                                       |  |
|--------------|---------------------------------------------------|--|
| /o filename  | Specify output file 'filename'. Default is a.out. |  |
| /m filename  | Create map file 'filename'.                       |  |
| /I pathlist  | Add directories to library search path.           |  |
| /k pathlist  | Add directories to linker script search path.     |  |
| /n length    | Specify number of lines per listing page.         |  |
| /h, /?       | Display help screen.                              |  |
| /a hexformat | Specify format of hex output file.                |  |
| /q           | Quiet mode.                                       |  |
| /d           | Don't create an absolute listing file.            |  |

# Key to 12, 14 and 16-bit PICmicro Family Instruction Sets

| Field | Description                                                                                                 |  |  |  |  |  |
|-------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| b     | Bit address within an 8 bit file register                                                                   |  |  |  |  |  |
| d     | Destination select; d = 0 Store result in W (f0A). d = 1 Store result in file register f. Default is d = 1. |  |  |  |  |  |
| f     | Register file address (0x00 to 0xFF)                                                                        |  |  |  |  |  |
| k     | Literal field, constant data or label                                                                       |  |  |  |  |  |
| W     | Working register (accumulator)                                                                              |  |  |  |  |  |
| x     | Don't care location                                                                                         |  |  |  |  |  |
| i     | Table pointer control; i = 0 Do not change. i = 1 Increment after instruction execution.                    |  |  |  |  |  |
| р     | Peripheral register file address (0x00 to 0x1f)                                                             |  |  |  |  |  |
| t     | Table byte select; $t = 0$ Perform operation on lower byte. $t = 1$ Perform operation on upper byte.        |  |  |  |  |  |
| PH:PL | Multiplication results registers                                                                            |  |  |  |  |  |

#### 12-Bit Core Instruction Set

#### 12-Bit Core Literal and Control Operations

| Hex | Mnemonic |   | Description                | Function                                   |
|-----|----------|---|----------------------------|--------------------------------------------|
| Ekk | ANDLW    | k | AND literal and W          | $k$ .AND. $W \rightarrow W$                |
| 9kk | CALL     | k | Call subroutine            | $PC + 1 \rightarrow TOS, k \rightarrow PC$ |
| 004 | CLRWDT   |   | Clear watchdog timer       | 0 → WDT (and<br>Prescaler if assigned)     |
| Akk | GOTO     | k | Goto address (k is 9 bits) | $k \rightarrow PC(9 \text{ bits})$         |
| Dkk | IORLW    | k | Incl. OR literal and W     | $k .OR. W \rightarrow W$                   |
| Ckk | MOVLW    | k | Move Literal to W          | $k \rightarrow W$                          |
| 002 | OPTION   |   | Load OPTION Register       | W → OPTION Register                        |
| 8kk | RETLW    | k | Return with literal in W   | $k \rightarrow W$ , TOS $\rightarrow$ PC   |
| 003 | SLEEP    |   | Go into Standby Mode       | $0 \rightarrow WDT$ , stop osc             |
| 00f | TRIS     | f | Tristate port f            | $W \rightarrow I/O$ control reg f          |
| Fkk | XORLW    | k | Exclusive OR literal and W | $k . XOR. W \rightarrow W$                 |

#### 12-Bit Core Byte Oriented File Register Operations

| Hex | Mnemo  | onic | Description               | Function                                  |
|-----|--------|------|---------------------------|-------------------------------------------|
| 1Cf | ADDWF  | f,d  | Add W and f               | $W + f \rightarrow d$                     |
| 14f | ANDWF  | f,d  | AND W and f               | W .AND. $f \rightarrow d$                 |
| 06f | CLRF   | f    | Clear f                   | $0 \rightarrow f$                         |
| 040 | CLRW   |      | Clear W                   | $0 \rightarrow W$                         |
| 24f | COMF   | f,d  | Complement f              | .NOT. $f \rightarrow d$                   |
| 0Cf | DECF   | f,d  | Decrement f               | $f - 1 \rightarrow d$                     |
| 2Cf | DECFSZ | f,d  | Decrement f, skip if zero | $f - 1 \rightarrow d$ , skip if zero      |
| 28f | INCF   | f,d  | Increment f               | $f + 1 \rightarrow d$                     |
| 3Cf | INCFSZ | f,d  | Increment f, skip if zero | $f + 1 \rightarrow d$ , skip if zero      |
| 10f | IORWF  | f,d  | Inclusive OR W and f      | W .OR. $f \rightarrow d$                  |
| 20f | MOVF   | f,d  | Move f                    | $f \rightarrow d$                         |
| 02f | MOVWF  | f    | Move W to f               | $W \rightarrow f$                         |
| 000 | NOP    |      | No operation              |                                           |
| 34f | RLF    | f,d  | Rotate left f             | register f                                |
| 30f | RRF    | f,d  | Rotate right f            | register f                                |
| 08f | SUBWF  | f,d  | Subtract W from f         | $f - W \rightarrow d$                     |
| 38f | SWAPF  | f,d  | Swap halves f             | $f(0:3) \rightarrow f(4:7) \rightarrow d$ |
| 18f | XORWF  | f,d  | Exclusive OR W and f      | W .XOR. $f \rightarrow d$                 |

#### 12-Bit Core Bit Oriented File Register Operations

| Hex | Mnemonic |     | Description             | Function             |
|-----|----------|-----|-------------------------|----------------------|
| 4bf | BCF      | f,b | Bit clear f             | $0 \rightarrow f(b)$ |
| 5bf | BSF      | f,b | Bit set f               | $1 \rightarrow f(b)$ |
| 6bf | BTFSC    | f,b | Bit test, skip if clear | skip if $f(b) = 0$   |
| 7bf | BTFSS    | f,b | Bit test, skip if set   | skip if f(b) = 1     |

#### 14-Bit Core Instruction Set

#### 14-Bit Core Literal and Control Operations

| Hex  | Mnemonic |   | Description                   | Function                                   |
|------|----------|---|-------------------------------|--------------------------------------------|
| 3Ekk | ADDLW    | k | Add literal to W              | $k + W \rightarrow W$                      |
| 39kk | ANDLW    | k | AND literal and W             | $k$ .AND. $W \rightarrow W$                |
| 2kkk | CALL     | k | Call subroutine               | $PC + 1 \rightarrow TOS, k \rightarrow PC$ |
| 0064 | CLRWDT T |   | Clear watchdog timer          | 0 → WDT<br>(and Prescaler)                 |
| 2kkk | GOTO     | k | Goto address (k is nine bits) | $k \rightarrow PC(9 \text{ bits})$         |
| 38kk | IORLW    | k | Incl. OR literal and W        | $k .OR. W \rightarrow W$                   |
| 30kk | MOVLW    | k | Move Literal to W             | $k \rightarrow W$                          |
| 0062 | OPTION   |   | Load OPTION register          | W → OPTION Register                        |
| 0009 | RETFIE   |   | Return from Interrupt         | $TOS \rightarrow PC, 1 \rightarrow GIE$    |
| 34kk | RETLW    | k | Return with literal in W      | $k \rightarrow W$ , TOS $\rightarrow$ PC   |
| 8000 | RETURN   |   | Return from subroutine        | $TOS \rightarrow PC$                       |
| 0063 | SLEEP    |   | Go into Standby Mode          | $0 \rightarrow WDT$ , stop oscillator      |
| 3Ckk | SUBLW    | k | Subtract W from literal       | $k - W \rightarrow W$                      |
| 006f | TRIS     | f | Tristate port f               | $W \rightarrow I/O$ control reg f          |
| 3Akk | XORLW    | k | Exclusive OR literal and W    | $k . XOR. W \rightarrow W$                 |

#### 14-Bit Core Byte Oriented File Register Operations

| Hex  | Mnemonic |     | Description               | Function                                  |
|------|----------|-----|---------------------------|-------------------------------------------|
| 07ff | ADDWF    | f,d | Add W and f               | $W + f \rightarrow d$                     |
| 05ff | ANDWF    | f,d | AND W and f               | W .AND. $f \rightarrow d$                 |
| 018f | CLRF     | f   | Clear f                   | $0 \rightarrow f$                         |
| 0100 | CLRW     |     | Clear W                   | $0 \rightarrow W$                         |
| 09ff | COMF     | f,d | Complement f              | .NOT. $f \rightarrow d$                   |
| 03ff | DECF     | f,d | Decrement f               | $f - 1 \rightarrow d$                     |
| 0Bff | DECFSZ   | f,d | Decrement f, skip if zero | $f - 1 \rightarrow d$ , skip if 0         |
| 0Aff | INCF     | f,d | Increment f               | $f + 1 \rightarrow d$                     |
| 0Fff | INCFSZ   | f,d | Increment f, skip if zero | $f + 1 \rightarrow d$ , skip if 0         |
| 04ff | IORWF    | f,d | Inclusive OR W and f      | W .OR. $f \rightarrow d$                  |
| 08ff | MOVF     | f,d | Move f                    | $f \rightarrow d$                         |
| 008f | MOVWF    | f   | Move W to f               | $W \rightarrow f$                         |
| 0000 | NOP      |     | No operation              |                                           |
| 0Dff | RLF      | f,d | Rotate left f             | register f 70                             |
| 0Cff | RRF      | f,d | Rotate right f            | register f                                |
| 02ff | SUBWF    | f,d | Subtract W from f         | $f - W \rightarrow d$                     |
| 0Eff | SWAPF    | f,d | Swap halves f             | $f(0:3) \rightarrow f(4:7) \rightarrow d$ |
| 06ff | XORWF    | f,d | Exclusive OR W and f      | W .XOR. $f \rightarrow d$                 |
| 1bff | BCF      | f,b | Bit clear f               | $0 \rightarrow f(b)$                      |
| 1bff | BSF      | f,b | Bit set f                 | $1 \rightarrow f(b)$                      |
| 1bff | BTFSC    | f,b | Bit test, skip if clear   | skip if f(b) = 0                          |
| 1bff | BTFSS    | f,b | Bit test, skip if set     | skip if f(b) = 1                          |

#### 12-Bit/14-Bit Core Special Instruction Mnemonics

| Mnem     |      | Description                    | Equiv                      | Status                |        |
|----------|------|--------------------------------|----------------------------|-----------------------|--------|
| Willelli | OHIC | Description                    | Operat                     | ion(s)                | Status |
| ADDCF    | f,d  | Add Carry to File              | BTFSC<br>INCF              | 3,0<br>f,d            | Z      |
| ADDDCF   | f,d  | Add Digit Carry to File        | BTFSC<br>INCF              | 3,1<br>f,d            | Z      |
| В        | k    | Branch                         | GOTO                       | k                     | -      |
| BC       | k    | Branch on Carry                | BTFSC<br>GOTO              | 3,0<br>k              | _      |
| BDC      | k    | Branch on Digit<br>Carry       | BTFSC<br>GOTO              | 3,1<br>k              | _      |
| BNC      | k    | Branch on No Carry             | BTFSS<br>GOTO              | 3,0<br>k              | _      |
| BNDC     | k    | Branch on No Digit<br>Carry    | BTFSS<br>GOTO              | 3,1<br>k              | _      |
| BNZ      | k    | Branch on No Zero              | BTFSS<br>GOTO              | 3,2<br>k              | -      |
| BZ       | k    | Branch on Zero                 | BTFSC<br>GOTO              | 3,2<br>k              | _      |
| CLRC     |      | Clear Carry                    | BCF                        | 3,0                   | -      |
| CLRDC    |      | Clear Digit Carry              | BCF                        | 3,1                   | -      |
| CLRZ     |      | Clear Zero                     | BCF                        | 3,2                   | -      |
| LCALL    | k    | Long Call                      | BCF/BSF<br>BCF/BSF<br>CALL | 0x0A,3<br>0x0A,4<br>k | -      |
| LGOTO    | k    | Long GOTO                      | BCF/BSF<br>BCF/BSF<br>GOTO | 0x0A,3<br>0x0A,4<br>k | -      |
| MOVFW    | f    | Move File to W                 | MOVF                       | f,0                   | Z      |
| NEGF     | f,d  | Negate File                    | COMF<br>INCF               | f,1<br>f,d            | Z      |
| SETC     |      | Set Carry                      | BSF                        | 3,0                   | _      |
| SETDC    |      | Set Digit Carry                | BSF                        | 3,1                   | _      |
| SETZ     |      | Set Zero                       | BSF                        | 3,2                   | -      |
| SKPC     |      | Skip on Carry                  | BTFSS                      | 3,0                   | -      |
| SKPDC    |      | Skip on Digit Carry            | BTFSS                      | 3,1                   | -      |
| SKPNC    |      | Skip on No Carry               | BTFSC                      | 3,0                   | _      |
| SKPNDC   |      | Skip on No Digit<br>Carry      | BTFSC                      | 3,1                   | _      |
| SKPNZ    |      | Skip on Non Zero               | BTFSC                      | 3,2                   | _      |
| SKPZ     |      | Skip on Zero                   | BTFSS                      | 3,2                   | -      |
| SUBCF    | f,d  | Subtract Carry from File       | BTFSC<br>DECF              | 3,0<br>f,d            | Z      |
| SUBDCF   | f,d  | Subtract Digit Carry from File | BTFSC<br>DECF              | 3,1<br>f,d            | Z      |
| TSTF     | f    | Test File                      | MOVF                       | f,1                   | Z      |

#### **16-Bit Core Instruction Set**

#### **16-Bit Core Data Movement Instructions**

| Hex  | Mnemonic |       | Description                                                                                                                                          | Function                                                                                                                                                                                                                             |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6pff | MOVFP    | f,p   | Move f to p                                                                                                                                          | $f \rightarrow p$                                                                                                                                                                                                                    |
| b8kk | MOVLB    | k     | Move literal to BSR                                                                                                                                  | $k \rightarrow BSR (3:0)$                                                                                                                                                                                                            |
| bakx | MOVLP    | k     | Move literal to RAM page select                                                                                                                      | k → BSR (7:4)                                                                                                                                                                                                                        |
| 4pff | MOVPF    | p,f   | Move p to f                                                                                                                                          | $p \rightarrow W$                                                                                                                                                                                                                    |
| 01ff | MOVWF    | f     | Move W to F                                                                                                                                          | $W \rightarrow f$                                                                                                                                                                                                                    |
| a8ff | TABLRD   | t,i,f | Read data from table<br>latch into file f, then<br>update table latch with<br>16-bit contents of<br>memory location<br>addressed by table<br>pointer | TBLATH → f if t=1,<br>TBLATL → f if t=0;<br>ProgMem(TBLPTR) → TBLAT;<br>TBLPTR + 1 → TBLPTR if i=1                                                                                                                                   |
| acff | TABLWT   | t,i,f | Write data from file f to<br>table latch and then<br>write 16-bit table latch<br>to program memory<br>location addressed by<br>table pointer         | $\begin{split} f &\rightarrow \text{TBLATH if } t = 1, \\ f &\rightarrow \text{TBLATL if } t = 0; \\ \text{TBLAT} &\rightarrow \text{ProgMem}(\text{TBLPTR}); \\ \text{TBLPTR} &+ 1 \rightarrow \text{TBLPTR if } i = 1 \end{split}$ |
| a0ff | TLRD     | t,f   | Read data from table latch into file f (table latch unchanged)                                                                                       | TBLATH $\rightarrow$ f if t = 1<br>TBLATL $\rightarrow$ f if t = 0                                                                                                                                                                   |
| a4ff | TLWT     | t,f   | Write data from file f into table latch                                                                                                              | $f \rightarrow TBLATH \text{ if } t = 1$<br>$f \rightarrow TBLATL \text{ if } t = 0$                                                                                                                                                 |

#### 16-Bit Core Arithmetic and Logical Instruction

| Hex  | Mnemonic |     | Description                   | Function                                   |
|------|----------|-----|-------------------------------|--------------------------------------------|
| b1kk | ADDLW    | k   | Add literal to W              | $(W + k) \rightarrow W$                    |
| 0eff | ADDWF    | f,d | Add W to F                    | $(W + f) \rightarrow d$                    |
| 10ff | ADDWFC   | f,d | Add W and Carry to f          | $(W + f + C) \rightarrow d$                |
| b5kk | ANDLW    | k   | AND Literal and W             | $(W .AND. k) \rightarrow W$                |
| 0aff | ANDWF    | f,d | AND W with f                  | $(W .AND. f) \rightarrow d$                |
| 28ff | CLRF     | f,d | Clear f and Clear d           | $0x00 \rightarrow f,0x00 \rightarrow d$    |
| 12ff | COMF     | f,d | Complement f                  | .NOT. $f \rightarrow d$                    |
| 2eff | DAW      | f,d | Dec. adjust W, store in f,d   | W adjusted $\rightarrow$ f and d           |
| 06ff | DECF     | f,d | Decrement f                   | $(f - 1) \rightarrow f$ and d              |
| 14ff | INCF     | f,d | Increment f                   | $(f + 1) \rightarrow f$ and d              |
| b3kk | IORLW    | k   | Inclusive OR literal with W   | $(W.OR.\ k) \to W$                         |
| 08ff | IORWF    | f,d | Inclusive or W with f         | $(W .OR. f) \rightarrow d$                 |
| b0kk | MOVLW    | k   | Move literal to W             | $k \rightarrow W$                          |
| bckk | MULLW    | k   | Multiply literal and W        | $(k \times W) \rightarrow PH:PL$           |
| 34ff | MULWF    | f   | Multiply W and f              | $(W \times f) \rightarrow PH:PL$           |
| 2cff | NEGW     | f,d | Negate W,<br>store in f and d | $(W+1) \rightarrow f, (W+1) \rightarrow d$ |
| 1aff | RLCF     | f,d | Rotate left through carry     | register f C ← 70                          |

## 16-Bit Core Arithmetic and Logical Instruction (Continued)

| Hex  | Mnemonic |     | Description                 | Function                                                    |
|------|----------|-----|-----------------------------|-------------------------------------------------------------|
| 22ff | RLNCF    | f,d | Rotate left (no carry)      | register f 70  ✓                                            |
| 18ff | RRCF     | f,d | Rotate right through carry  | register f  C → 70                                          |
| 20ff | RRNCF    | f,d | Rotate right (no carry)     | register f  70                                              |
| 2aff | SETF     | f,d | Set f and Set d             | $0xff \rightarrow f, 0xff \rightarrow d$                    |
| b2kk | SUBLW    | k   | Subtract W from literal     | $(k - W) \rightarrow W$                                     |
| 04ff | SUBWF    | f,d | Subtract W from f           | $(f - W) \rightarrow d$                                     |
| 02ff | SUBWFB   | f,d | Subtract from f with borrow | $(f - W - c) \rightarrow d$                                 |
| 1cff | SWAPF    | f,d | Swap f                      | $f(0:3) \rightarrow d(4:7),$<br>$f(4:7) \rightarrow d(0:3)$ |
| b4kk | XORLW    | k   | Exclusive OR literal with W | $(W . XOR. k) \rightarrow W$                                |
| 0cff | XORWF    | f,d | Exclusive OR W with f       | $(W . XOR. f) \rightarrow d$                                |

#### 16-Bit Core Bit Handling Instructions

| Hex  | Mnemonic |     | Description             | Function                      |
|------|----------|-----|-------------------------|-------------------------------|
| 8bff | BCF      | f,b | Bit clear f             | $0 \rightarrow f(b)$          |
| 8bff | BSF      | f,b | Bit set f               | $1 \rightarrow f(b)$          |
| 9bff | BTFSC    | f,b | Bit test, skip if clear | skip if $f(b) = 0$            |
| 9bff | BTFSS    | f,b | Bit test, skip if set   | skip if f(b) = 1              |
| 3bff | BTG      | f,b | Bit toggle f            | .NOT. $f(b) \rightarrow f(b)$ |

#### **16-Bit Core Program Control Instructions**

| Hex  | Mnemonic |     | Description                             | Function                                                                                                              |
|------|----------|-----|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| ekkk | CALL     | k   | Subroutine call (within 8k page)        | $\begin{array}{c} PC+1 \to TOS, k \to PC(12:0), \\ k(12:8) \to PCLATH(4:0), \\ PC(15:13) \to PCLATH(7:5) \end{array}$ |
| 31ff | CPFSEQ   | f   | Compare f/w, skip if f = w              | f-W, skip if f = W                                                                                                    |
| 32ff | CPFSGT   | f   | Compare f/w, skip if f > w              | f-W, skip if f > W                                                                                                    |
| 30ff | CPFSLT   | f   | Compare f/w, skip if f < w              | f-W, skip if f < W                                                                                                    |
| 16ff | DECFSZ   | f,d | Decrement f, skip if 0                  | $(f-1) \rightarrow d$ , skip if 0                                                                                     |
| 26ff | DCFSNZ   | f,d | Decrement f, skip if not 0              | $(f-1) \rightarrow d$ , skip if not 0                                                                                 |
| ckkk | GOTO     | k   | Unconditional branch<br>(within 8k)     | $k \to PC(12:0)$<br>$k(12:8) \to PCLATH(4:0),$<br>$PC(15:13) \to PCLATH(7:5)$                                         |
| 1eff | INCFSZ   | f,d | Increment f, skip if zero               | $(f+1) \rightarrow d$ , skip if 0                                                                                     |
| 24ff | INFSNZ   | f,d | Increment f, skip if not zero           | $(f+1) \rightarrow d$ , skip if not 0                                                                                 |
| b7kk | LCALL    | k   | Long Call (within 64k)                  | $ \begin{array}{l} (PC+1) \rightarrow TOS;  k \rightarrow PCL, \\ (PCLATH) \rightarrow PCH \end{array} $              |
| 0005 | RETFIE   |     | Return from interrupt, enable interrupt | $ \begin{array}{l} (PCLATH) \to PCH:k \to PCL \\ 0 \to GLINTD \end{array} $                                           |
| b6kk | RETLW    | k   | Return with literal in W                | $k \rightarrow W$ , TOS $\rightarrow$ PC, (PCLATH unchanged)                                                          |

### 16-Bit Core Program Control Instructions (Continued)

| Hex  | Mnemonic | Description          | Function                       |
|------|----------|----------------------|--------------------------------|
| 0002 | RETURN   |                      | TOS → PC<br>(PCLATH unchanged) |
| 33ff | TSTFSZ f | Test f, skip if zero | skip if f = 0                  |

#### 16-Bit Core Special Control Instructions

| Hex  | Mnemonic | Description          | Function                                                                                                                                           |
|------|----------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0004 | CLRWDT   | Clear watchdog timer | $\begin{array}{l} 0 \rightarrow \text{WDT, } 0 \rightarrow \text{WDT prescaler,} \\ 1 \rightarrow \text{PD, } 1 \rightarrow \text{TO} \end{array}$ |
| 0003 | SLEEP    | Enter Sleep Mode     | Stop oscillator, power down, $0 \rightarrow WDT$ , $0 \rightarrow WDT$ Prescaler $1 \rightarrow PD$ , $1 \rightarrow TO$                           |

## **Key to Enhanced 16-Bit Core Instruction Set**

| Field           | Description                                                             |
|-----------------|-------------------------------------------------------------------------|
| FILE ADDRESSES  |                                                                         |
| f               | 8-bit file register address                                             |
| fs              | 12-bit source file register address                                     |
| fd              | 12-bit destination file register address                                |
| dest            | W register if d = 0; file register if d = 1                             |
| r               | 0, 1 or 2 for FSR number                                                |
| LITERALS        |                                                                         |
| kk              | 8-bit literal value                                                     |
| kb              | 4-bit literal value                                                     |
| kc              | bits 8-11 of 12-bit literal value                                       |
| kd              | bits 0-7 of 12-bit literal value                                        |
| OFFSETS, ADDRES | SSES                                                                    |
| nn              | 8-bit relative offset (signed, 2's complement)                          |
| nd              | 11-bit relative offset (signed, 2's complement)                         |
| ml              | bits 0-7 of 20-bit program memory address                               |
| mm              | bits 8-19 of 20-bit program memory address                              |
| BITS            |                                                                         |
| b               | bits 9-11; bit address                                                  |
| d               | bit 9; 0=W destination; 1=f destination                                 |
| а               | bit 8; 0=access block; 1=BSR selects bank                               |
| s               | bit 0 (bit 8 for CALL); 0=no update; 1(fast)=update/save W, STATUS, BSR |

## **Enhanced 16-Bit Core Instruction Set**

#### **Enhanced 16-Bit Core Literal Operations**

| Hex          | Mnemonic |         | Description                              | Function                                                                                                                                                                                    |
|--------------|----------|---------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0F <i>kk</i> | ADDLW    | kk      | ADD literal to WREG                      | $W+kk \rightarrow W$                                                                                                                                                                        |
| 0B <i>kk</i> | ANDLW    | kk      | AND literal with WREG                    | W .AND. $kk \rightarrow W$                                                                                                                                                                  |
| 0004         | CLRWD    |         | Clear watchdog timer                     | $0 \rightarrow WDT, 0 \rightarrow WDT$<br>postscaler,<br>$1 \rightarrow TO, 1 \rightarrow PD$                                                                                               |
| 0007         | DAW      |         | Decimal Adjust WREG                      | if W<3:0> >9 or DC=1,<br>W<3:0>+6 $\rightarrow$ W<3:0>,<br>else W<3:0> $\rightarrow$ W<3:0>;<br>if W<7:4> >9 or C=1,<br>W<7:4>+6 $\rightarrow$ W<7:4>,<br>else W<7:4> $\rightarrow$ W<7:4>; |
| 09 <i>kk</i> | IORLW    | kk      | Inclusive OR literal with WREG           | W .OR. $kk \rightarrow W$                                                                                                                                                                   |
| EEkc<br>F0kd | LFSR     | r,kd:kc | Load 12-bit Literal to FSR (second word) | kd:kc → FSRr                                                                                                                                                                                |
| 01 <i>kb</i> | MOVLB    | kb      | Move literal to low nibble in BSR        | $kb \rightarrow BSR$                                                                                                                                                                        |
| 0E <i>kk</i> | MOVLW    | kk      | Move literal to WREG                     | $kk \rightarrow W$                                                                                                                                                                          |
| 0D <i>kk</i> | MULLW    | kk      | Multiply literal with WREG               | W * kk $\rightarrow$ PRODH:PRODL                                                                                                                                                            |
| 08 <i>kk</i> | SUBLW    | kk      | Subtract W from literal                  | $kk-W \rightarrow W$                                                                                                                                                                        |
| 0A <i>kk</i> | XORLW    | kk      | Exclusive OR literal with WREG           | W .XOR. $kk \rightarrow W$                                                                                                                                                                  |

#### **Enhanced 16-Bit Core Memory Operations**

| Hex  | Mnemonic | Description                               | Function                                                              |
|------|----------|-------------------------------------------|-----------------------------------------------------------------------|
| 8000 | TBLRD*   | Table Read (no change to TBLPTR)          | Prog Mem<br>(TBLPTR) → TABLAT                                         |
| 0009 | TBLRD*+  | Table Read<br>(post-increment<br>TBLPTR)  | Prog Mem $(TBLPTR) \rightarrow TABLAT$ $TBLPTR +1 \rightarrow TBLPTR$ |
| 000A | TBLRD*-  | Table Read<br>(post-decrement<br>TBLPTR)  | Prog Mem (TBLPTR) →<br>TABLAT<br>TBLPTR -1 → TBLPTR                   |
| 000B | TBLRD+*  | Table Read<br>(pre-increment<br>TBLPTR)   | TBLPTR +1 → TBLPTR<br>Prog Mem (TBLPTR) →<br>TABLAT                   |
| 000C | TBLWT*   | Table Write (no change to TBLPTR)         | TABLAT → Prog<br>Mem(TBLPTR)                                          |
| 000D | TBLWT*+  | Table Write<br>(post-increment<br>TBLPTR) | TABLAT → Prog<br>Mem(TBLPTR)<br>TBLPTR +1 → TBLPTR                    |
| 000E | TBLWT*-  | Table Write<br>(post-decrement<br>TBLPTR) | TABLAT → Prog<br>Mem(TBLPTR)<br>TBLPTR -1 → TBLPTR                    |
| 000F | TBLWT+*  | Table Write<br>(pre-increment<br>TBLPTR)  | TBLPTR +1 → TBLPTR<br>TABLAT → Prog<br>Mem(TBLPTR)                    |

#### **Enhanced 16-Bit Core Control Operations**

| Hex                         | Mnen   | onic    | Description                                         | Function                                                                                                                                                                                                                                      |
|-----------------------------|--------|---------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |        |         | •                                                   |                                                                                                                                                                                                                                               |
| E2nn                        | BC     | nn      | Relative Branch if<br>Carry                         | if C=1, PC+2+2*nn→PC,<br>else PC+2→PC                                                                                                                                                                                                         |
| E6nn                        | BN     | nn      | Relative Branch if<br>Negative                      | if N=1, PC+2+2*nn→PC,<br>else PC+2→PC                                                                                                                                                                                                         |
| E3nn                        | BNC    | nn      | Relative Branch if Not Carry                        | if C=0, PC+2+2*nn→PC,<br>else PC+2→PC                                                                                                                                                                                                         |
| E7nn                        | BNN    | nn      | Relative Branch if Not<br>Negative                  | if N=0, PC+2+2*nn→PC,<br>else PC+2→PC                                                                                                                                                                                                         |
| E5nn                        | BNOV   | nn      | Relative Branch if Not<br>Overflow                  | if OV=0, PC+2+2*nn→PC, else PC+2→PC                                                                                                                                                                                                           |
| E1 <i>nn</i>                | BNZ    | nn      | Relative Branch if Not Zero                         | if Z=0, PC+2+2*nn→PC,<br>else PC+2→PC                                                                                                                                                                                                         |
| E4nn                        | BOV    | nn      | Relative Branch if<br>Overflow                      | if OV=1, PC+2+2*nn→PC,<br>else PC+2→PC                                                                                                                                                                                                        |
| D0nd                        | BRA    | nd      | Unconditional relative branch                       | PC+2+2*nd→PC                                                                                                                                                                                                                                  |
| E0nn                        | BZ     | nn      | Relative Branch if Zero                             | if Z=1, PC+2+2*nn→PC,<br>else PC+2→PC                                                                                                                                                                                                         |
| ECml<br>Fmm                 | CALL   | mm:ml,s | Absolute Subroutine<br>Call (second word)           | $\begin{array}{l} \text{PC+4} \rightarrow \text{TOS}, \\ \text{mm:ml} \rightarrow \text{PC<20:1>}, \\ \text{if s=1, W} \rightarrow \text{WS}, \\ \text{STATUS} \rightarrow \text{STATUSS}, \\ \text{BSR} \rightarrow \text{BSRS} \end{array}$ |
| EF <i>ml</i><br>F <i>mm</i> | GOTO   | mm:ml   | Absolute Branch (second word)                       | mm:ml → PC<20:1>                                                                                                                                                                                                                              |
| 0000                        | NOP    |         | No Operation                                        | No operation                                                                                                                                                                                                                                  |
| 0006                        | POP    |         | Pop Top/stack                                       | TOS-1 → TOS                                                                                                                                                                                                                                   |
| 0005                        | PUSH   |         | Push Top/stack                                      | PC +2 → TOS                                                                                                                                                                                                                                   |
| D8nd                        | RCALL  | nd      | Relative Subroutine<br>Call                         | PC+2 → TOS,<br>PC+2+2*nd→PC                                                                                                                                                                                                                   |
| 00FF                        | RESET  |         | Generate <u>a Reset</u> (same as MCLR reset)        | same as MCLR reset                                                                                                                                                                                                                            |
| 0010                        | RETFIE | S       | Return from interrupt<br>(and enable<br>interrupts) | TOS → PC, 1 → GIE/GIEH or PEIE/GIEL, if s=1, WS → W, STATUSS → STATUS, BSRS → BSR, PCLATU/PCLATH are unchanged                                                                                                                                |
| 0Ckk                        | RETLW  | kk      | Return from subroutine, literal in W                | $kk \rightarrow W$                                                                                                                                                                                                                            |
| 0012                        | RETURN | S       | Return from subroutine                              | TOS → PC, if s=1, WS → W<br>STATUSS → STATUS,<br>BSRS → BSR,<br>PCLATU/PCLATH are<br>unchanged                                                                                                                                                |
| 0003                        | SLEEP  |         | Enter SLEEP Mode                                    | $0 \rightarrow WDT, 0 \rightarrow WDT$<br>postscaler,<br>$1 \rightarrow TO, 0 \rightarrow PD$                                                                                                                                                 |

#### **Enhanced 16-Bit Core Bit Operations**

| Hex | Mne   | monic | Description                  | Function                                  |
|-----|-------|-------|------------------------------|-------------------------------------------|
| 9bf | BCF   | f,b,a | Bit Clear f                  | $0 \rightarrow f < b >$                   |
| 8bf | BSF   | f,b,a | Bit Set f                    | 1 → f <b></b>                             |
| Bbf | BTFSC | f,b,a | Bit test f,<br>skip if clear | if f <b>=0, PC+4→PC,<br/>else PC+2→PC</b> |
| Abf | BTFSS | f,b,a | Bit test f,<br>skip if set   | if f <b>=1, PC+4→PC,<br/>else PC+2→PC</b> |
| 7bf | BTG   | f,b,a | Bit Toggle f                 | $f < b > \rightarrow f < b >$             |

#### **Enhanced 16-Bit Core File Register Operation**

|             |        |       |                                          | -                                                                                                  |
|-------------|--------|-------|------------------------------------------|----------------------------------------------------------------------------------------------------|
| Hex         | Mnen   | onic  | Description                              | Function                                                                                           |
| 24 <i>f</i> | ADDWF  | f,d,a | ADD WREG to f                            | W+f $\rightarrow$ dest                                                                             |
| 20 <i>f</i> | ADDWFC | f,d,a | ADD WREG and<br>Carry bit to f           | W+f+C → dest                                                                                       |
| 14 <i>f</i> | ANDWF  | f,d,a | AND WREG with f                          | W .AND. $f \rightarrow dest$                                                                       |
| 6Af         | CLRF   | f,a   | Clear f                                  | $0 \rightarrow f$                                                                                  |
| 1Cf         | COMF   | f,d,a | Complement f                             | $f \rightarrow dest$                                                                               |
| 62 <i>f</i> | CPFSEQ | f,a   | Compare f with WREG, skip if f=WREG      | f–W, if f=W, PC+4 $\rightarrow$ PC else PC+2 $\rightarrow$ PC                                      |
| 64 <i>f</i> | CPFSGT | f,a   | Compare f with WREG, skip if f > WREG    | f–W, if f > W, PC+4 $\rightarrow$ PC else PC+2 $\rightarrow$ PC                                    |
| 60 <i>f</i> | CPFSLT | f,a   | Compare f with WREG, skip if f < WREG    | f–W, if f < W, PC+4 $\rightarrow$ PC else PC+2 $\rightarrow$ PC                                    |
| 04 <i>f</i> | DECF   | f,d,a | Decrement f                              | f–1 → dest                                                                                         |
| 2Cf         | DECFSZ | f,d,a | Decrement f,<br>skip if 0                | $f-1 \rightarrow dest$ , if dest=0,<br>PC+4 $\rightarrow$ PC<br>else PC+2 $\rightarrow$ PC         |
| 4Cf         | DCFSNZ | f,d,a | Decrement f,<br>skip if not 0            | f–1 → dest, if dest $\neq$ 0,<br>PC+4 → PC<br>else PC+2 → PC                                       |
| 28f         | INCF   | f,d,a | Increment f                              | f+1 → dest                                                                                         |
| 3Cf         | INCFSZ | f,d,a | Increment f,<br>skip if 0                | f+1 → dest, if dest=0,<br>PC+4 → PC<br>else PC+2 → PC                                              |
| 48f         | INFSNZ | f,d,a | Increment f,<br>skip if not 0            | $f+1 \rightarrow dest$ , if $dest \neq 0$ ,<br>$PC+4 \rightarrow PC$<br>$else PC+2 \rightarrow PC$ |
| 10 <i>f</i> | IORWF  | f,d,a | Inclusive OR WREG with f                 | W .OR. f $\rightarrow$ dest                                                                        |
| 50 <i>f</i> | MOVF   | f,d,a | Move f                                   | $f \rightarrow dest$                                                                               |
| Cfs<br>Ffd  | MOVFF  | fs,fd | Move fs (first word) to fd (second word) | $fs \rightarrow fd$                                                                                |
| 6E <i>f</i> | MOVWF  | f,a   | Move WREG to f                           | $W \rightarrow f$                                                                                  |
| 02 <i>f</i> | MULWF  | f,a   | Multiply WREG with f                     | $W * f \rightarrow PRODH:PRODL$                                                                    |
| 6Cf         | NEGF   | f,a   | Negate f                                 | $f + 1 \rightarrow PRODH:PRODL$                                                                    |
| 34 <i>f</i> | RLCF   | f,d,a | Rotate left f through<br>Carry           | register f                                                                                         |
| 44f         | RLNCF  | f,d,a | Rotate left f (no carry)                 | register f 70  ✓                                                                                   |

## Enhanced 16-Bit Core File Register Operation (Continued)

| Hex         | Mnemonic |       | Description                      | Function                                                   |  |  |  |  |  |
|-------------|----------|-------|----------------------------------|------------------------------------------------------------|--|--|--|--|--|
| 30 <i>f</i> | RRCF     | f,d,a | Rotate right f through Carry     | register f 70                                              |  |  |  |  |  |
| 40 <i>f</i> | RRNCF    | f,d,a | Rotate right f (no carry)        | register f  70                                             |  |  |  |  |  |
| 68 <i>f</i> | SETF     | f,a   | Set f                            | $0xFF \rightarrow f$                                       |  |  |  |  |  |
| 54 <i>f</i> | SUBFWB   | f,d,a | Subtract f from WREG with Borrow | W - f - C $\rightarrow$ dest                               |  |  |  |  |  |
| 5Cf         | SUBWF    | f,d,a | Subtract WREG from f             | $f - W \rightarrow dest$                                   |  |  |  |  |  |
| 58 <i>f</i> | SUBWFB   | f,d,a | Subtract WREG from f with Borrow | $f - W - C \rightarrow dest$                               |  |  |  |  |  |
| 38 <i>f</i> | SWAPF    | f,d,a | Swap nibbbles of f               | f<3:0> → dest<7:4>,<br>f<7:4> → dest<3:0>                  |  |  |  |  |  |
| 66 <i>f</i> | TSTFSZ   | f,a   | Test f, skip if 0                | $PC+4 \rightarrow PC$ , if f=0, else $PC+2 \rightarrow PC$ |  |  |  |  |  |
| 18 <i>f</i> | XORWF    | f,d,a | Exclusive OR WREG with f         | W .XOR. $f \rightarrow dest$                               |  |  |  |  |  |

# PIC18CXXX Core Special Function Register Files

| PRODH    | FF4 | INDF1    | FE7 |
|----------|-----|----------|-----|
| PRODL    | FF3 | POSTINC1 | FE6 |
| TOSU     | FFF | POSTDEC1 | FE5 |
| TOSH     | FFE | PREINC1  | FE4 |
| TOSL     | FFD | PLUSW1   | FE3 |
| STKPTR   | FFC | FSR1H    | FE2 |
| PCLATU   | FFB | FSR1L    | FE1 |
| PCLATH   | FFA | INDF2    | FDF |
| PCL      | FF9 | POSTINC2 | FDE |
| TBLPTRU  | FF8 | POSTDEC2 | FDD |
| TBLPTRH  | FF7 | PREINC2  | FDC |
| TBLPTRL  | FF6 | PLUSW2   | FDB |
| TABLAT   | FF5 | FSR2H    | FDA |
| INDF0    | FEF | FSR2L    | FD9 |
| POSTINC0 | FEE | WREG     | FE8 |
| POSTDEC0 | FED | BSR      | FE0 |
| PREINC0  | FEC | STATUS   | FD8 |
| PLUSW0   | FEB | INTCON   | FF2 |
| FSR0H    | FEA | INTCON2  | FF1 |
| FSR0L    | FE9 | INTCON3  | FF0 |

#### **ASCII Character Set**

|                             |     | Most Significant Character |     |       |     |   |   |   |     |  |  |
|-----------------------------|-----|----------------------------|-----|-------|-----|---|---|---|-----|--|--|
|                             | Hex |                            |     | 2     | 3   | 4 | 5 | 6 | 7   |  |  |
| Least Significant Character | 0   |                            |     | Space | 0   | @ | Р | ` | р   |  |  |
|                             | 1   | SOH                        | DC1 | !     | 1   | Α | Q | а | q   |  |  |
|                             | 2   | STX                        | DC2 | •     | 2   | В | R | b | r   |  |  |
|                             | 3   | ETX                        | DC3 | #     | 3   | O | S | С | S   |  |  |
|                             | 4   | EOT                        | DC4 | \$    | 4   | D | Т | d | t   |  |  |
|                             | 5   | ENQ                        | NAK | %     | 5   | Е | U | е | u   |  |  |
|                             | 6   | ACK                        | SYN | &     | 6   | F | V | f | ٧   |  |  |
|                             | 7   | Bell                       | ETB |       | 7   | G | W | g | w   |  |  |
|                             | 8   | BS                         | CAN | (     | 8   | Ι | Х | h | Х   |  |  |
|                             | 9   | HT                         | EM  | )     | 9   | - | Υ | i | у   |  |  |
|                             | Α   | LF                         | SUB | *     | ••• | J | Z | j | Z   |  |  |
|                             | В   | VT                         | ESC | +     | • ; | K | [ | k | {   |  |  |
|                             | С   | FF                         | FS  | ,     | <   | L | \ | I |     |  |  |
|                             | D   | CR                         | GS  | -     | Ш   | М | ] | m | }   |  |  |
|                             | Е   | SO                         | RS  |       | ^   | N | ٨ | n | ~   |  |  |
|                             | F   | SI                         | US  | /     | ?   | 0 | _ | 0 | DEL |  |  |

#### MPLIB™ Usage Format

MPLIB object librarian is invoked with the following syntax:

mplib [/q] /{ctdrx} LIBRARY [MEMBER...]

options:

/c create library; creates a new LIBRARY with the listed

MEMBER(s)

/t list members; prints a table showing the names of the members

in the LIBRARY

/d delete member; deletes MEMBER(s) from the LIBRARY; if no

MEMBER is specified the LIBRARY is not altered

/r add/replace member; if MEMBER(s) exist in the LIBRARY, then they

are replaced, otherwise MEMBER is appended

to the end of the LIBRARY

/x extract member; if MEMBER(s) exist in the LIBRARY, then they

are extracted. If no MEMBER is specified, all

members will be extracted

/q quiet mode; no output is displayed

#### MPLIB Usage Examples

Suppose a library named dsp.lib is to be created from three object modules named fft.o, fir.o and iir.o. The following command line would produce the desired results:

```
mplib /c dsp.lib fft.o fir.o iir.o
```

To display the names of the object modules contained in a library file names dsp.lib, the following command line would be appropriate:

mplib /t dsp.lib



Microchip Technology Inc.
2355 W. Chandler Blvd. • Chandler, AZ 85224 U.S.A.
Phone: 480-792-7200 • Fax: 480-792-9210
www.microchip.com

The Microchip name and logo, the Microchip logo, PIC and PICmicro are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. MPASM, MPLINK and MPLIB are trademarks of Microchip Technology in the U.S.A. and other countries.

© 2003 Microchip Technology Incorporated. All rights reserved. Printed in the U.S.A. 1/03 DS30400F

